#include <iostream>
using namespace std;

int dfs3(int l,int b){
	if(b == 1)
		return l+1;
	int ans=0;
	for(int i=0;i<=l-(b-1);i++)
		ans += dfs3(l-1-i,b-1);
	return ans;
}


int main(){
	int n;
	cin>>n;
	int b=0,l=0;
	for(int i=0;i<n;i++){
		int ll;
		cin>>ll;
		if(ll == 1)
			b++;
		else
			l++;
	}
	if(b == 0){
		cout<<1;
		return 0;
	}
	if(l == 0){
		cout<<1;
		return 0;
	}
	if(l == 1  &&  b == 1){
		cout<<2;
		return 0;
	}
	if(b > l){
		int ans=1;
		for(int i=b-1;i>=b-1-l+1;i--)
			ans *= i;
		for(int i=1;i<=l;i++)
			ans /= i;
		cout<<ans;
		return 0;
	}
	else if(b == l){
		cout<<3;
		return 0;
	}
	else if(b < l){
		cout<<dfs3(l,b);
		return 0;
	}
	return 0;
}
